<!doctype html>
<html itemscope itemtype="http://schema.org/WebPage" lang="zh-cn" class="no-js">
  <head>
    <meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<meta name="generator" content="Hugo 0.121.1">
<meta name="robots" content="index, follow">


<link rel="shortcut icon" href="/favicons/favicon.ico" >
<link rel="apple-touch-icon" href="/favicons/apple-touch-icon-180x180.png" sizes="180x180">
<link rel="icon" type="image/png" href="/favicons/favicon-16x16.png" sizes="16x16">
<link rel="icon" type="image/png" href="/favicons/favicon-32x32.png" sizes="32x32">
<link rel="icon" type="image/png" href="/favicons/android-36x36.png" sizes="36x36">
<link rel="icon" type="image/png" href="/favicons/android-48x48.png" sizes="48x48">
<link rel="icon" type="image/png" href="/favicons/android-72x72.png" sizes="72x72">
<link rel="icon" type="image/png" href="/favicons/android-96x96.png" sizes="96x96">
<link rel="icon" type="image/png" href="/favicons/android-144x144.png" sizes="144x144">
<link rel="icon" type="image/png" href="/favicons/android-192x192.png" sizes="192x192">

<title>蚂蚁集团大规模 Serverless 降本增效实践 | SOFAServerless</title>
<meta name="description" content="作者：刘煜、赵真灵、刘晶、代巍、孙仁恩等
蚂蚁集团业务痛点 蚂蚁集团过去 20 年经历了微服务架构飞速演进，与此同时应用数量和复杂度爆发式增长，带来了严重的企业成本和效率问题：
大量长尾应用 CPU 使用率不足 10%，却由于多地域高可用消耗大量机器。 应用一次构建&#43;发布速度慢，平均 10 分钟，研发效率低下且无法快速弹性。 多人开发的应用，功能必须攒一起 “赶火车”，迭代互相阻塞，协作和交付效率低下。 业务 SDK 和部分框架升级对业务有较高打扰，无法做到基础设施对业务微感甚至无感。 业务资产难以沉淀，大中台建设成本高昂。 蚂蚁集团 SOFAServerless 使用场景 合并部署降成本 在企业中 “80%” 的长尾应用仅服务 “20%” 的流量，蚂蚁集团也不例外。
在蚂蚁集团存在大量长尾应用，每个长尾应用至少需要 预发布、灰度、生产 3 个环境，每个环境最少需要部署 3 个机房，每个机房又必须保持 2 台机器高可用，因此大量长尾应用 CPU 使用率不足 10%。
通过使用 SOFAServerless，蚂蚁集团对长尾应用进行了服务器裁撤，借助类委托隔离、资源监控、日志监控等技术，在保证稳定性的前提下，实现了多应用的合并部署，极大降低了业务的运维成本和资源成本。
此外，采用这种模式，小应用可以不走应用申请上线流程也不需要申请机器，可以直接部署到业务通用基座之上，从而帮助小流量业务实现了快速创新。
模块化研发极致提效 在蚂蚁集团，很多部门存在开发者人数较多的应用，由于人数多，导致环境抢占、联调抢占、测试资源抢占情况严重，互相阻塞，一人 Delay 多人 Delay，导致需求交付效率低下。
通过使用 SOFAServerless，蚂蚁集团将协作人数较多的应用，一步步重构为基座代码和不同功能的模块代码。基座代码沉淀了各种 SDK 和业务的公共接口，由专人维护，而模块代码则内聚了某一个功能领域特有的业务逻辑，可以调用本地基座接口。模块采用热部署实现了十秒级构建、发布、伸缩，同时模块开发者完全不用关心服务器和基础设施，这样普通应用便以很低的接入成本实现了 Serverless 的研发体验。
以蚂蚁集团资金业务为例，资金通过将应用拆分为一个基座与多个模块，实现了发布运维、组织协作、集群流量隔离多个维度的极致提效。
蚂蚁集团资金业务 SOFAServerless 架构演进和实践，详见：https://mp.weixin.qq.com/s/uN0SyzkW_elYIwi03gis-Q
通用基座屏蔽基础设施 在蚂蚁集团，各种 SDK 的升级打扰、构建发布慢是痛点问题。借助 SOFAServerless 通用基座模式，蚂蚁集团帮助部分应用实现了基础设施微感升级，同时应用的构建与发布速度也从 600 秒减少到了 90 秒。
在 SOFAServerless 通用基座模式里，基座会提前启动好，这些预启动的基座包含了各种通用中间件、二方包和三方包的 SDK。借助 SOFAServerless 构建插件，业务应用会被构建成 FatJar 包，在发布业务应用新版本时，调度器会选择一台没有安装模块的空基座将模块应用 FatJar 热部署到基座，装有模块的老基座服务器会异步的替换成新服务器（空基座）。">
<meta property="og:title" content="蚂蚁集团大规模 Serverless 降本增效实践" />
<meta property="og:description" content="作者：刘煜、赵真灵、刘晶、代巍、孙仁恩等
蚂蚁集团业务痛点 蚂蚁集团过去 20 年经历了微服务架构飞速演进，与此同时应用数量和复杂度爆发式增长，带来了严重的企业成本和效率问题：
大量长尾应用 CPU 使用率不足 10%，却由于多地域高可用消耗大量机器。 应用一次构建&#43;发布速度慢，平均 10 分钟，研发效率低下且无法快速弹性。 多人开发的应用，功能必须攒一起 “赶火车”，迭代互相阻塞，协作和交付效率低下。 业务 SDK 和部分框架升级对业务有较高打扰，无法做到基础设施对业务微感甚至无感。 业务资产难以沉淀，大中台建设成本高昂。 蚂蚁集团 SOFAServerless 使用场景 合并部署降成本 在企业中 “80%” 的长尾应用仅服务 “20%” 的流量，蚂蚁集团也不例外。
在蚂蚁集团存在大量长尾应用，每个长尾应用至少需要 预发布、灰度、生产 3 个环境，每个环境最少需要部署 3 个机房，每个机房又必须保持 2 台机器高可用，因此大量长尾应用 CPU 使用率不足 10%。
通过使用 SOFAServerless，蚂蚁集团对长尾应用进行了服务器裁撤，借助类委托隔离、资源监控、日志监控等技术，在保证稳定性的前提下，实现了多应用的合并部署，极大降低了业务的运维成本和资源成本。
此外，采用这种模式，小应用可以不走应用申请上线流程也不需要申请机器，可以直接部署到业务通用基座之上，从而帮助小流量业务实现了快速创新。
模块化研发极致提效 在蚂蚁集团，很多部门存在开发者人数较多的应用，由于人数多，导致环境抢占、联调抢占、测试资源抢占情况严重，互相阻塞，一人 Delay 多人 Delay，导致需求交付效率低下。
通过使用 SOFAServerless，蚂蚁集团将协作人数较多的应用，一步步重构为基座代码和不同功能的模块代码。基座代码沉淀了各种 SDK 和业务的公共接口，由专人维护，而模块代码则内聚了某一个功能领域特有的业务逻辑，可以调用本地基座接口。模块采用热部署实现了十秒级构建、发布、伸缩，同时模块开发者完全不用关心服务器和基础设施，这样普通应用便以很低的接入成本实现了 Serverless 的研发体验。
以蚂蚁集团资金业务为例，资金通过将应用拆分为一个基座与多个模块，实现了发布运维、组织协作、集群流量隔离多个维度的极致提效。
蚂蚁集团资金业务 SOFAServerless 架构演进和实践，详见：https://mp.weixin.qq.com/s/uN0SyzkW_elYIwi03gis-Q
通用基座屏蔽基础设施 在蚂蚁集团，各种 SDK 的升级打扰、构建发布慢是痛点问题。借助 SOFAServerless 通用基座模式，蚂蚁集团帮助部分应用实现了基础设施微感升级，同时应用的构建与发布速度也从 600 秒减少到了 90 秒。
在 SOFAServerless 通用基座模式里，基座会提前启动好，这些预启动的基座包含了各种通用中间件、二方包和三方包的 SDK。借助 SOFAServerless 构建插件，业务应用会被构建成 FatJar 包，在发布业务应用新版本时，调度器会选择一台没有安装模块的空基座将模块应用 FatJar 热部署到基座，装有模块的老基座服务器会异步的替换成新服务器（空基座）。" />
<meta property="og:type" content="article" />
<meta property="og:url" content="/user-cases/ant-group/" /><meta property="article:section" content="user-cases" />

<meta property="article:modified_time" content="2023-10-30T23:00:45+08:00" />

<meta itemprop="name" content="蚂蚁集团大规模 Serverless 降本增效实践">
<meta itemprop="description" content="作者：刘煜、赵真灵、刘晶、代巍、孙仁恩等
蚂蚁集团业务痛点 蚂蚁集团过去 20 年经历了微服务架构飞速演进，与此同时应用数量和复杂度爆发式增长，带来了严重的企业成本和效率问题：
大量长尾应用 CPU 使用率不足 10%，却由于多地域高可用消耗大量机器。 应用一次构建&#43;发布速度慢，平均 10 分钟，研发效率低下且无法快速弹性。 多人开发的应用，功能必须攒一起 “赶火车”，迭代互相阻塞，协作和交付效率低下。 业务 SDK 和部分框架升级对业务有较高打扰，无法做到基础设施对业务微感甚至无感。 业务资产难以沉淀，大中台建设成本高昂。 蚂蚁集团 SOFAServerless 使用场景 合并部署降成本 在企业中 “80%” 的长尾应用仅服务 “20%” 的流量，蚂蚁集团也不例外。
在蚂蚁集团存在大量长尾应用，每个长尾应用至少需要 预发布、灰度、生产 3 个环境，每个环境最少需要部署 3 个机房，每个机房又必须保持 2 台机器高可用，因此大量长尾应用 CPU 使用率不足 10%。
通过使用 SOFAServerless，蚂蚁集团对长尾应用进行了服务器裁撤，借助类委托隔离、资源监控、日志监控等技术，在保证稳定性的前提下，实现了多应用的合并部署，极大降低了业务的运维成本和资源成本。
此外，采用这种模式，小应用可以不走应用申请上线流程也不需要申请机器，可以直接部署到业务通用基座之上，从而帮助小流量业务实现了快速创新。
模块化研发极致提效 在蚂蚁集团，很多部门存在开发者人数较多的应用，由于人数多，导致环境抢占、联调抢占、测试资源抢占情况严重，互相阻塞，一人 Delay 多人 Delay，导致需求交付效率低下。
通过使用 SOFAServerless，蚂蚁集团将协作人数较多的应用，一步步重构为基座代码和不同功能的模块代码。基座代码沉淀了各种 SDK 和业务的公共接口，由专人维护，而模块代码则内聚了某一个功能领域特有的业务逻辑，可以调用本地基座接口。模块采用热部署实现了十秒级构建、发布、伸缩，同时模块开发者完全不用关心服务器和基础设施，这样普通应用便以很低的接入成本实现了 Serverless 的研发体验。
以蚂蚁集团资金业务为例，资金通过将应用拆分为一个基座与多个模块，实现了发布运维、组织协作、集群流量隔离多个维度的极致提效。
蚂蚁集团资金业务 SOFAServerless 架构演进和实践，详见：https://mp.weixin.qq.com/s/uN0SyzkW_elYIwi03gis-Q
通用基座屏蔽基础设施 在蚂蚁集团，各种 SDK 的升级打扰、构建发布慢是痛点问题。借助 SOFAServerless 通用基座模式，蚂蚁集团帮助部分应用实现了基础设施微感升级，同时应用的构建与发布速度也从 600 秒减少到了 90 秒。
在 SOFAServerless 通用基座模式里，基座会提前启动好，这些预启动的基座包含了各种通用中间件、二方包和三方包的 SDK。借助 SOFAServerless 构建插件，业务应用会被构建成 FatJar 包，在发布业务应用新版本时，调度器会选择一台没有安装模块的空基座将模块应用 FatJar 热部署到基座，装有模块的老基座服务器会异步的替换成新服务器（空基座）。">
<meta itemprop="dateModified" content="2023-10-30T23:00:45+08:00" />
<meta itemprop="wordCount" content="112">
<meta itemprop="keywords" content="" /><meta name="twitter:card" content="summary"/><meta name="twitter:title" content="蚂蚁集团大规模 Serverless 降本增效实践"/>
<meta name="twitter:description" content="作者：刘煜、赵真灵、刘晶、代巍、孙仁恩等
蚂蚁集团业务痛点 蚂蚁集团过去 20 年经历了微服务架构飞速演进，与此同时应用数量和复杂度爆发式增长，带来了严重的企业成本和效率问题：
大量长尾应用 CPU 使用率不足 10%，却由于多地域高可用消耗大量机器。 应用一次构建&#43;发布速度慢，平均 10 分钟，研发效率低下且无法快速弹性。 多人开发的应用，功能必须攒一起 “赶火车”，迭代互相阻塞，协作和交付效率低下。 业务 SDK 和部分框架升级对业务有较高打扰，无法做到基础设施对业务微感甚至无感。 业务资产难以沉淀，大中台建设成本高昂。 蚂蚁集团 SOFAServerless 使用场景 合并部署降成本 在企业中 “80%” 的长尾应用仅服务 “20%” 的流量，蚂蚁集团也不例外。
在蚂蚁集团存在大量长尾应用，每个长尾应用至少需要 预发布、灰度、生产 3 个环境，每个环境最少需要部署 3 个机房，每个机房又必须保持 2 台机器高可用，因此大量长尾应用 CPU 使用率不足 10%。
通过使用 SOFAServerless，蚂蚁集团对长尾应用进行了服务器裁撤，借助类委托隔离、资源监控、日志监控等技术，在保证稳定性的前提下，实现了多应用的合并部署，极大降低了业务的运维成本和资源成本。
此外，采用这种模式，小应用可以不走应用申请上线流程也不需要申请机器，可以直接部署到业务通用基座之上，从而帮助小流量业务实现了快速创新。
模块化研发极致提效 在蚂蚁集团，很多部门存在开发者人数较多的应用，由于人数多，导致环境抢占、联调抢占、测试资源抢占情况严重，互相阻塞，一人 Delay 多人 Delay，导致需求交付效率低下。
通过使用 SOFAServerless，蚂蚁集团将协作人数较多的应用，一步步重构为基座代码和不同功能的模块代码。基座代码沉淀了各种 SDK 和业务的公共接口，由专人维护，而模块代码则内聚了某一个功能领域特有的业务逻辑，可以调用本地基座接口。模块采用热部署实现了十秒级构建、发布、伸缩，同时模块开发者完全不用关心服务器和基础设施，这样普通应用便以很低的接入成本实现了 Serverless 的研发体验。
以蚂蚁集团资金业务为例，资金通过将应用拆分为一个基座与多个模块，实现了发布运维、组织协作、集群流量隔离多个维度的极致提效。
蚂蚁集团资金业务 SOFAServerless 架构演进和实践，详见：https://mp.weixin.qq.com/s/uN0SyzkW_elYIwi03gis-Q
通用基座屏蔽基础设施 在蚂蚁集团，各种 SDK 的升级打扰、构建发布慢是痛点问题。借助 SOFAServerless 通用基座模式，蚂蚁集团帮助部分应用实现了基础设施微感升级，同时应用的构建与发布速度也从 600 秒减少到了 90 秒。
在 SOFAServerless 通用基座模式里，基座会提前启动好，这些预启动的基座包含了各种通用中间件、二方包和三方包的 SDK。借助 SOFAServerless 构建插件，业务应用会被构建成 FatJar 包，在发布业务应用新版本时，调度器会选择一台没有安装模块的空基座将模块应用 FatJar 热部署到基座，装有模块的老基座服务器会异步的替换成新服务器（空基座）。"/>




<link rel="preload" href="/scss/main.min.526354c4efc1a4747972ed64c3be00f7db62aec5f0a3e6ae42052f97e2675d86.css" as="style">
<link href="/scss/main.min.526354c4efc1a4747972ed64c3be00f7db62aec5f0a3e6ae42052f97e2675d86.css" rel="stylesheet" integrity="">

<script
  src="https://code.jquery.com/jquery-3.6.3.min.js"
  integrity="sha512-STof4xm1wgkfm7heWqFJVn58Hm3EtS31XFaagaa8VMReCXAkQnJZ+jEy8PCC/iT18dFy95WcExNHFTqLyp72eQ=="
  crossorigin="anonymous"></script>
<link rel="stylesheet" href="/css/prism.css"/>
<link href="/img/logo.svg" rel="icon" type="image/svg">
<link href="/search/pagefind-ui.css" rel="stylesheet">
<script src="/search/pagefind-ui.js" type="text/javascript"></script>

<script>
    window.addEventListener('DOMContentLoaded', (event) => {
        new PagefindUI({ element: ".td-search" });
    });
</script>


<script>
var doNotTrack = false;
if (!doNotTrack) {
	window.ga=window.ga||function(){(ga.q=ga.q||[]).push(arguments)};ga.l=+new Date;
	ga('create', 'G-DZ8Q3F0GZ7', 'auto');
	
	ga('send', 'pageview');
}
</script>
<script async src='https://www.google-analytics.com/analytics.js'></script>

<script async src="https://www.googletagmanager.com/gtag/js?id=G-DZ8Q3F0GZ7"></script>
<script>
var doNotTrack = false;
if (!doNotTrack) {
	window.dataLayer = window.dataLayer || [];
	function gtag(){dataLayer.push(arguments);}
	gtag('js', new Date());
	gtag('config', 'G-DZ8Q3F0GZ7');
}
</script>
  </head>
  <body class="td-page">
    <header>
      <nav class="td-navbar navbar-dark js-navbar-scroll">
<div class="container-fluid flex-column flex-md-row">
  <a class="navbar-brand" href="/"><span class="navbar-brand__logo navbar-logo"><svg width="26" height="29" viewBox="0 0 26 29" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><defs><linearGradient x1="52.6662558%" y1="95.7312514%" x2="35.7492678%" y2="11.0078657%" id="linearGradient-wxw43fh1xd-1"><stop stop-color="#9822e4" offset="0"/><stop stop-color="#e643fa" offset="86.0585504%"/><stop stop-color="#f876ff" offset="100%"/></linearGradient><path d="M15.9275871 1.54432572 15.936122 1.5594269 15.9445709 1.57457632 5.01248933 7.79418913 7.699 9.304l8.8412359-4.72420311.8668497-.49490764C17.4171462 4.0791454 17.4272394 4.07345885 17.4373647 4.06782987c1.474137-.81952243 3.3335154-.28885241 4.1530379 1.18528466L10.875 11.088l2.864 1.609 8.843271-5.6213813c1.1038914-.6292563 2.5021428-.23250173 3.1230817.88617614C25.8984381 8.30965565 25.9998668 8.70204694 25.9998668 9.10116416V19.9436637c0 1.3476373-1.002317 2.484932-2.3392704 2.6542897L22.9421516 22.6889619V10.4257286L20.457252 12.0257475 20.457758 23.6880152c0 1.2665471-1.0267393 2.2932864-2.2932864 2.2932864H17.59115L17.590252 13.8727475 15.106 15.473 15.1067564 27.0588825c0 1.0695936-.855616100000001 1.9366704-1.911072 1.9366704C12.8696714 28.9955529 12.5490782 28.9110348 12.2643947 28.7500365L1.63270516 23.3171586C.159863707 22.5645249-.423980046 20.7604209.328653641 19.2875794L.372104915 19.2057013 12.0490412 25.0797183 12.049 22.086 1.98952173 16.7675786C.51279311 15.9867912-.0513787599 14.1567129.729408593 12.6799843L.744416289 12.6519572.759717752 12.6240895 12.049 18.593 12.0490412 15.2566254 1.7391964 9.45898637C1.44132502 9.2850324 1.19527431 9.0328708 1.02697438 8.72907568c-.516688418-.93266477-.189466545-2.11320819.7308705-2.63681754C6.19445786 3.56812633 9.52191759 1.67502747 11.7402241.412961569L11.7628911.400065593c1.4660277-.834070345 3.3306257-.321767634 4.164696 1.144260127z" id="path-wxw43fh1xd-2"/><linearGradient x1="50.6099966%" y1="31.6743333%" x2="50.2419846%" y2="73.0702907%" id="linearGradient-wxw43fh1xd-4"><stop stop-color="#8200b5" offset="0"/><stop stop-color="#8200b5" stop-opacity="0" offset="100%"/></linearGradient><linearGradient x1="50.6028666%" y1="31.6743333%" x2="50.2391561%" y2="73.0702907%" id="linearGradient-wxw43fh1xd-5"><stop stop-color="#8200b5" offset="0"/><stop stop-color="#8200b5" stop-opacity="0" offset="100%"/></linearGradient><linearGradient x1="90.8235257%" y1="50%" x2="3.24041867%" y2="52.9415572%" id="linearGradient-wxw43fh1xd-6"><stop stop-color="#dd3ff7" stop-opacity="0" offset="0"/><stop stop-color="#ca23e4" offset="100%"/></linearGradient><linearGradient x1="74.3272776%" y1="35.8586031%" x2="19.6895996%" y2="19.3309621%" id="linearGradient-wxw43fh1xd-7"><stop stop-color="#b800d1" stop-opacity="0" offset="0"/><stop stop-color="#ae00c5" offset="100%"/></linearGradient><linearGradient x1="97.0070676%" y1="71.8003287%" x2="11.3661868%" y2="30.5044309%" id="linearGradient-wxw43fh1xd-8"><stop stop-color="#940ec7" offset="0"/><stop stop-color="#c435f0" stop-opacity="0" offset="100%"/></linearGradient></defs><g id="页面-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><g id="首页" transform="translate(-24.000000, -18.000000)"><g id="编组-4" transform="translate(24.000133, 16.000000)"><g id="路径-6-copy-2" transform="translate(0.000000, 2.004447)"><mask id="mask-wxw43fh1xd-3" fill="#fff"><use xlink:href="#path-wxw43fh1xd-2"/></mask><use id="Mask" fill="url(#linearGradient-wxw43fh1xd-1)" fill-rule="nonzero" xlink:href="#path-wxw43fh1xd-2"/><path d="M12.0490412 15.2684078 13.03943 15.5167092C14.3279076 16.0478608 15.1686754 17.3038563 15.1686754 18.6975193V18.7421449v9.047164l-3.1196342-1.4070083V15.2684078z" id="Path-114-Copy-2" fill="url(#linearGradient-wxw43fh1xd-4)" opacity=".69047619" mask="url(#mask-wxw43fh1xd-3)"/><path d="M22.9421516 10.4227424 23.8594661 10.2542707C24.8889759 10.219744 25.7876765 10.946368 25.9694916 11.9602841L26.0763097 12.5559692 26.0617858 22.9064645l-3.1196342-1.4070082V10.4227424z" id="Path-114-Copy-2" fill="url(#linearGradient-wxw43fh1xd-5)" opacity=".69047619" mask="url(#mask-wxw43fh1xd-3)"/><polygon id="Path-41" fill="url(#linearGradient-wxw43fh1xd-6)" mask="url(#mask-wxw43fh1xd-3)" points="7.6326499 9.31647968 11.9297751 6.77228295 14.9765833 9.31647968 10.7681311 11.1500753"/><path d="M6.16852974 12.7326226C8.05429918 13.6181711 7.86496926 14.83948 8.18831704 15.006813 8.70089861 15.2720748 9.14143095 17.098905 9.86115602 17.1695013 10.6949216 17.2512836 11.6478081 10.8552079 10.3936906 10.4556578 9.48069361 10.1647855 7.32719679 9.49121213 3.93320016 8.43493769c-.63204609 1.86851711.11306377 3.30107871 2.23532958 4.29768491z" fill="url(#linearGradient-wxw43fh1xd-7)" mask="url(#mask-wxw43fh1xd-3)" transform="translate(7.357416, 12.802608) rotate(-347.000000) translate(-7.357416, -12.802608)"/><polygon id="Path-43" fill="url(#linearGradient-wxw43fh1xd-8)" mask="url(#mask-wxw43fh1xd-3)" points="12.0699788 18.5615749 6.27140769 15.1359473 5.30588708 19.0963147 12.0699788 22.1120507"/></g></g></g></g></svg></span><span class="navbar-brand__name">SOFAServerless</span></a>
  <div class="td-navbar-nav-scroll ms-md-auto" id="main_navbar">
    <ul class="navbar-nav">
      <li class="nav-item">
        <a class="nav-link" href="/home/"><span>首页</span></a>
      </li>
      <li class="nav-item">
        <a class="nav-link" href="/docs/"><span>产品文档</span></a>
      </li>
      <li class="nav-item">
        <a class="nav-link" href="/blog/"><span>最新信息</span></a>
      </li>
      <li class="nav-item">
        <a class="nav-link" href="/community/"><span>参与社区</span></a>
      </li>
      <li class="nav-item">
        <a class="nav-link active" href="/user-cases/"><span>用户案例</span></a>
      </li>
      <li class="nav-item dropdown d-none d-lg-block">
        <div class="dropdown">
  <a class="nav-link dropdown-toggle" href="#" role="button" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">中文</a>
  <ul class="dropdown-menu">
    <li><a class="dropdown-item" href="/no/"></a></li>
    </ul>
</div></li>
      </ul>
  </div>
  <div class="d-none d-lg-block">
    <div class="td-search">
  <div class="td-search__icon"></div>
  <input type="search" class="td-search__input form-control td-search-input" placeholder="站内搜索…" aria-label="站内搜索…" autocomplete="off">
</div>

  </div>
</div>
</nav>
    </header>
    <div class="container-fluid td-outer">
      <div class="td-main">
        <div class="row flex-xl-nowrap">
          <aside class="col-12 col-md-3 col-xl-2 td-sidebar d-print-none">
            <div id="td-sidebar-menu" class="td-sidebar__inner">
  <form class="td-sidebar__search d-flex align-items-center">
    <div class="td-search">
  <div class="td-search__icon"></div>
  <input type="search" class="td-search__input form-control td-search-input" placeholder="站内搜索…" aria-label="站内搜索…" autocomplete="off">
</div>

    <button class="btn btn-link td-sidebar__toggle d-md-none p-0 ms-3 fas fa-bars" type="button" data-bs-toggle="collapse" data-bs-target="#td-section-nav" aria-controls="td-section-nav" aria-expanded="false" aria-label="Toggle section navigation">
    </button>
  </form>
  <nav class="collapse td-sidebar-nav" id="td-section-nav">
    <div class="td-sidebar-nav__section nav-item dropdown d-block d-lg-none">
      <div class="dropdown">
  <a class="nav-link dropdown-toggle" href="#" role="button" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">中文</a>
  <ul class="dropdown-menu">
    <li><a class="dropdown-item" href="/no/"></a></li>
    </ul>
</div>
    </div>
    <ul class="td-sidebar-nav__section pe-md-3 ul-0">
      <li class="td-sidebar-nav__section-title td-sidebar-nav__section with-child active-path" id="m-user-cases-li">
  <a href="/user-cases/" class="align-left ps-0 td-sidebar-link td-sidebar-link__section tree-root" id="m-user-cases"><span class="">用户案例</span></a>
  <ul class="ul-1">
    <li class="td-sidebar-nav__section-title td-sidebar-nav__section without-child active-path" id="m-user-casesant-group-li">
  <a href="/user-cases/ant-group/" class="align-left ps-0 active td-sidebar-link td-sidebar-link__page" id="m-user-casesant-group"><span class="td-sidebar-nav-active-item">蚂蚁集团大规模 Serverless 降本增效实践</span></a>
</li><li class="td-sidebar-nav__section-title td-sidebar-nav__section without-child" id="m-user-casesalibaba-aidc-li">
  <a href="/user-cases/alibaba-aidc/" class="align-left ps-0 td-sidebar-link td-sidebar-link__page" id="m-user-casesalibaba-aidc"><span class="">阿里国际数字商业集团中台业务三倍提效</span></a>
</li><li class="td-sidebar-nav__section-title td-sidebar-nav__section without-child" id="m-user-casesall-users-li">
  <a href="/user-cases/all-users/" class="align-left ps-0 td-sidebar-link td-sidebar-link__page" id="m-user-casesall-users"><span class="">SOFAServerless 所有企业案例</span></a>
</li>
  </ul>
</li>
    </ul>
  </nav>
</div>

          </aside>
          <aside class="d-none d-xl-block col-xl-2 td-sidebar-toc d-print-none">
            
<div class="td-page-meta ms-2 pb-1 pt-2 mb-0">
<a href="https://github.com/sofastack/sofa-serverless/tree/master/docs/content/zh-cn/user-cases/ant-group.md" class="td-page-meta--view" target="_blank" rel="noopener"><i class="fa-solid fa-file-lines fa-fw"></i> 查看页面源码</a>
  <a href="https://github.com/sofastack/sofa-serverless/edit/master/docs/content/zh-cn/user-cases/ant-group.md" class="td-page-meta--edit" target="_blank" rel="noopener"><i class="fa-solid fa-pen-to-square fa-fw"></i> 编辑此页</a>
  <a href="https://github.com/sofastack/sofa-serverless/new/master/docs/content/zh-cn/user-cases/ant-group.md?filename=change-me.md&amp;value=---%0Atitle%3A&#43;%22Long&#43;Page&#43;Title%22%0AlinkTitle%3A&#43;%22Short&#43;Nav&#43;Title%22%0Aweight%3A&#43;100%0Adescription%3A&#43;%3E-%0A&#43;&#43;&#43;&#43;&#43;Page&#43;description&#43;for&#43;heading&#43;and&#43;indexes.%0A---%0A%0A%23%23&#43;Heading%0A%0AEdit&#43;this&#43;template&#43;to&#43;create&#43;your&#43;new&#43;page.%0A%0A%2A&#43;Give&#43;it&#43;a&#43;good&#43;name%2C&#43;ending&#43;in&#43;%60.md%60&#43;-&#43;e.g.&#43;%60getting-started.md%60%0A%2A&#43;Edit&#43;the&#43;%22front&#43;matter%22&#43;section&#43;at&#43;the&#43;top&#43;of&#43;the&#43;page&#43;%28weight&#43;controls&#43;how&#43;its&#43;ordered&#43;amongst&#43;other&#43;pages&#43;in&#43;the&#43;same&#43;directory%3B&#43;lowest&#43;number&#43;first%29.%0A%2A&#43;Add&#43;a&#43;good&#43;commit&#43;message&#43;at&#43;the&#43;bottom&#43;of&#43;the&#43;page&#43;%28%3C80&#43;characters%3B&#43;use&#43;the&#43;extended&#43;description&#43;field&#43;for&#43;more&#43;detail%29.%0A%2A&#43;Create&#43;a&#43;new&#43;branch&#43;so&#43;you&#43;can&#43;preview&#43;your&#43;new&#43;file&#43;and&#43;request&#43;a&#43;review&#43;via&#43;Pull&#43;Request.%0A" class="td-page-meta--child" target="_blank" rel="noopener"><i class="fa-solid fa-pen-to-square fa-fw"></i> 添加子页面</a>
  <a href="https://github.com/sofastack/sofa-serverless/issues/new?title=%e8%9a%82%e8%9a%81%e9%9b%86%e5%9b%a2%e5%a4%a7%e8%a7%84%e6%a8%a1%20Serverless%20%e9%99%8d%e6%9c%ac%e5%a2%9e%e6%95%88%e5%ae%9e%e8%b7%b5" class="td-page-meta--issue" target="_blank" rel="noopener"><i class="fa-solid fa-list-check fa-fw"></i> 提交文档问题</a>
  <a id="print" href="/user-cases/_print/"><i class="fa-solid fa-print fa-fw"></i> 整节打印</a>

</div>

            <div class="td-toc">
        <nav id="TableOfContents">
  <ul>
    <li><a href="#合并部署降成本">合并部署降成本</a></li>
    <li><a href="#模块化研发极致提效">模块化研发极致提效</a></li>
    <li><a href="#通用基座屏蔽基础设施">通用基座屏蔽基础设施</a></li>
    <li><a href="#低成本实现高效中台">低成本实现高效中台</a></li>
  </ul>
</nav>
      </div>
    
            

          </aside>
          <main class="col-12 col-md-9 col-xl-8 ps-md-5" role="main">
            
  

            
            
<div class="td-content">
	<h1>蚂蚁集团大规模 Serverless 降本增效实践</h1>
	
	<header class="article-meta">
		
</header>
	<blockquote>
<p>作者：刘煜、赵真灵、刘晶、代巍、孙仁恩等</p>
</blockquote>
<h1 id="蚂蚁集团业务痛点">蚂蚁集团业务痛点</h1>
<p>蚂蚁集团过去 20 年经历了微服务架构飞速演进，与此同时应用数量和复杂度爆发式增长，带来了严重的企业成本和效率问题：</p>
<ol>
<li>大量长尾应用 CPU 使用率<strong>不足 10%</strong>，却由于多地域高可用消耗大量机器。</li>
<li>应用一次构建+发布速度慢，平均 <strong>10 分钟</strong>，研发效率低下且无法快速<strong>弹性</strong>。</li>
<li>多人开发的应用，功能必须攒一起 “<strong>赶火车</strong>”，迭代互相<strong>阻塞</strong>，协作和交付效率低下。</li>
<li>业务 SDK 和部分框架升级对业务有较<strong>高打扰</strong>，无法做到基础设施对业务微感甚至无感。</li>
<li>业务资产难以沉淀，大中台建设<strong>成本高昂</strong>。</li>
</ol>
<h1 id="蚂蚁集团-sofaserverless-使用场景">蚂蚁集团 SOFAServerless 使用场景</h1>
<h2 id="合并部署降成本">合并部署降成本</h2>
<p>在企业中 “<strong>80%</strong>” 的长尾应用仅服务 “<strong>20%</strong>” 的流量，蚂蚁集团也不例外。<br />在蚂蚁集团存在大量长尾应用，每个长尾应用至少需要 预发布、灰度、生产 3 个环境，每个环境最少需要部署 3 个机房，每个机房又必须保持 2 台机器高可用，因此大量长尾应用 CPU 使用率<strong>不足 10%</strong>。<br />通过使用 SOFAServerless，蚂蚁集团对长尾应用进行了服务器裁撤，借助类委托隔离、资源监控、日志监控等技术，在保证稳定性的前提下，实现了多应用的合并部署，极大降低了业务的运维成本和资源成本。<br /><img src="https://intranetproxy.alipay.com/skylark/lark/0/2023/png/671/1697010009124-285a0679-2462-434d-8d75-2aa5a7ede7be.png#clientId=u2fc31cce-a2b2-4&from=paste&height=182&id=ub16bde42&originHeight=364&originWidth=1438&originalType=binary&ratio=2&rotation=0&showTitle=false&size=163395&status=done&style=none&taskId=u4de74533-5e86-41e0-bb44-9bc8203b9c9&title=&width=719" width="700"><br />此外，采用这种模式，小应用可以不走应用申请上线流程也不需要申请机器，可以直接部署到业务通用基座之上，从而帮助小流量业务实现了快速创新。</p>
<h2 id="模块化研发极致提效">模块化研发极致提效</h2>
<p>在蚂蚁集团，很多部门存在开发者人数较多的应用，由于人数多，导致环境抢占、联调抢占、测试资源抢占情况严重，互相阻塞，一人 Delay 多人 Delay，导致需求交付效率低下。<br />通过使用 SOFAServerless，蚂蚁集团将协作人数较多的应用，一步步重构为基座代码和不同功能的模块代码。基座代码沉淀了各种 SDK 和业务的公共接口，由专人维护，而模块代码则内聚了某一个功能领域特有的业务逻辑，可以调用本地基座接口。模块采用热部署实现了<strong>十秒级</strong>构建、发布、伸缩，同时模块开发者<strong>完全不用关心</strong>服务器和基础设施，这样普通应用便以<strong>很低的接入成本</strong>实现了 <strong>Serverless</strong> 的研发体验。<br />以蚂蚁集团资金业务为例，资金通过将应用拆分为一个基座与多个模块，实现了发布运维、组织协作、集群流量隔离多个维度的极致提效。<br /><img src="https://intranetproxy.alipay.com/skylark/lark/0/2023/png/671/1697011295180-dfc3def2-968b-4456-95f5-447cfe6b8282.png#clientId=u2fc31cce-a2b2-4&from=paste&height=814&id=u32abf9c9&originHeight=1628&originWidth=2924&originalType=binary&ratio=2&rotation=0&showTitle=false&size=1774843&status=done&style=none&taskId=u08c84de5-b5eb-4c19-b724-9826d13e397&title=&width=1462" width="1200"></p>
<p>蚂蚁集团资金业务 SOFAServerless 架构演进和实践，详见：<a href="https://mp.weixin.qq.com/s/uN0SyzkW_elYIwi03gis-Q">https://mp.weixin.qq.com/s/uN0SyzkW_elYIwi03gis-Q</a></p>
<h2 id="通用基座屏蔽基础设施">通用基座屏蔽基础设施</h2>
<p>在蚂蚁集团，各种 SDK 的升级打扰、构建发布慢是痛点问题。借助 SOFAServerless 通用基座模式，蚂蚁集团帮助部分应用实现了基础设施微感升级，同时应用的构建与发布速度也从 <strong>600 秒</strong>减少到了 <strong>90 秒</strong>。<br /><br/><img src="https://intranetproxy.alipay.com/skylark/lark/0/2023/png/671/1697016458930-17177051-a51f-4a88-956f-6cabfd4a7b97.png#clientId=u2fc31cce-a2b2-4&from=paste&height=265&id=u9661d43a&originHeight=530&originWidth=2370&originalType=binary&ratio=2&rotation=0&showTitle=false&size=450843&status=done&style=none&taskId=uf4bf486d-f806-4164-b786-9cd2e0ff7d3&title=&width=1185" width="800"></p>
<p>在 SOFAServerless 通用基座模式里，基座会提前启动好，这些预启动的基座包含了各种通用中间件、二方包和三方包的 SDK。借助 SOFAServerless 构建插件，业务应用会被构建成 FatJar 包，在发布业务应用新版本时，调度器会选择一台没有安装模块的空基座将模块应用 FatJar 热部署到基座，装有模块的老基座服务器会异步的替换成新服务器（空基座）。<br />基座由专职团队负责维护和升级，对模块应用开发者来说，便享受到了基础设施无感升级和极速构建发布体验。</p>
<h2 id="低成本实现高效中台">低成本实现高效中台</h2>
<p>在蚂蚁集团，有不少中台类业务，典型如各个业务线的玩法、营销、公益、搜索推荐、广告投放等。通过使用 SOFAServerless，这些中台业务逐渐演进成了基座 + 模块的交付方式，其中基座代码沉淀了通用逻辑，也定义了一些 SPI，而模块负责实现这些 SPI，流量会从基座代码进入，调用模块的 SPI 实现。<br />在中台场景下，模块一般都很轻，甚至只是一个代码片段，大部分模块都能在 <strong>5 秒内</strong>发布、扩容完成，而且模块开发者完全不关心基础设施，享受到了极致的 Serverless 研发体验。<br />以蚂蚁集团<strong>搜索推荐</strong>业务中台为例，搜索推荐业务将公共依赖、通用逻辑、流程引擎全部下沉到基座，并且定义了一些 SPI，搜索推荐算法由各个模块开发者实现，当前搜索推荐已经接入了 <strong>1000+</strong> 模块，平均代码发布上线不到 <strong>1 天</strong>，真正实现了代码的 “<strong>朝写夕发</strong>”。<br /><br/><img src="https://intranetproxy.alipay.com/skylark/lark/0/2023/png/671/1697024085963-a8b74e7b-37d5-469f-97da-7ef7b3e6889f.png#clientId=u2fc31cce-a2b2-4&from=paste&height=684&id=u44c95749&originHeight=1368&originWidth=1412&originalType=binary&ratio=2&rotation=0&showTitle=false&size=728809&status=done&style=none&taskId=u34dbef7c-95c4-4e42-9613-0a25f3362a3&title=&width=706" width="700"></p>
<h1 id="总结与规划">总结与规划</h1>
<p>SOFAServerless 在蚂蚁集团历经 3 年多的演进与打磨，目前已在所有业务线完成落地，支撑了全集团 <strong>1/4</strong> 的在线流量，帮助全集团实现了功能平均上线从 12 天<strong>减少到 6 天</strong>、长尾应用<strong>服务器砍半</strong>、<strong>秒级发布运维</strong>的极致降本增效结果。<br />未来，蚂蚁集团会更大规模推广 SOFAServerless 研发模式，并持续建设弹性能力，做到更极致的弹性体验和绿色低碳。同时，我们也会重点投入开源能力建设，希望和社区同学共同打造极致的模块化技术体系，为各行各业的软件创造技术价值，助力企业实现降本提效。</p>

	<style>
  .feedback--answer {
    display: inline-block;
  }
  .feedback--answer-no {
    margin-left: 1em;
  }
  .feedback--response {
    display: none;
    margin-top: 1em;
  }
  .feedback--response__visible {
    display: block;
  }
</style>
<div class="d-print-none">
<h2 class="feedback--title">Feedback</h2>
<p class="feedback--question">Was this page helpful?</p>
<button class="btn btn-primary mb-4 feedback--answer feedback--answer-yes">Yes</button>
<button class="btn btn-primary mb-4 feedback--answer feedback--answer-no">No</button>
<p class="feedback--response feedback--response-yes">
  很高兴文档对您有帮助! 欢迎<a href="https://github.com/sofastack/sofa-serverless/issues/new?assignees=&labels=&projects=&template=feature_request.md">为社区提建议</a>。
</p>
<p class="feedback--response feedback--response-no">
  很抱歉文档对您没帮助。邀请您<a href="https://github.com/sofastack/sofa-serverless/issues/new?assignees=&labels=&projects=&template=feature_request.md">为文档提建议</a>或者<a href="https://github.com/sofastack/sofa-serverless/tree/master/user-docs/content/zh-cn">直接完善该文档</a>。
</p>
</div>
<script>
  const yesButton = document.querySelector('.feedback--answer-yes');
  const noButton = document.querySelector('.feedback--answer-no');
  const yesResponse = document.querySelector('.feedback--response-yes');
  const noResponse = document.querySelector('.feedback--response-no');
  const disableButtons = () => {
    yesButton.disabled = true;
    noButton.disabled = true;
  };
  const sendFeedback = (value) => {
    if (typeof ga !== 'function') return;
    const args = {
      command: 'send',
      hitType: 'event',
      category: 'Helpful',
      action: 'click',
      label: window.location.pathname,
      value: value
    };
    ga(args.command, args.hitType, args.category, args.action, args.label, args.value);
  };
  yesButton.addEventListener('click', () => {
    yesResponse.classList.add('feedback--response__visible');
    disableButtons();
    sendFeedback(1);
  });
  noButton.addEventListener('click', () => {
    noResponse.classList.add('feedback--response__visible');
    disableButtons();
    sendFeedback(0);
  });
</script>

		<br />
	<div class="text-muted mt-5 pt-3 border-top">
  最后修改 October 30, 2023: <a href="https://github.com/sofastack/sofa-serverless/commit/f751b32b35936a73b0feddfd7fefc0b439ddaf32">update home (f751b32b)</a>
</div>

</div>


          </main>
        </div>
      </div>
      <footer class="td-footer row d-print-none">
  <div class="container-fluid">
    <div class="row mx-md-2">
      <div class="col-6 col-sm-4 text-xs-center order-sm-2">
        
        
        
<ul class="td-footer__links-list">
  
  <li class="td-footer__links-item" data-bs-toggle="tooltip" title="通过社区交流群" aria-label="通过社区交流群">
    <a target="_blank" rel="noopener" href="/docs/contribution-guidelines/communication-channel/" aria-label="通过社区交流群">
      <i class="fab fa-twitter"></i>
    </a>
  </li>
  
</ul>

        
        
      </div>
      <div class="col-6 col-sm-4 text-end text-xs-center order-sm-3">
        
        
        
<ul class="td-footer__links-list">
  
  <li class="td-footer__links-item" data-bs-toggle="tooltip" title="看这里" aria-label="看这里">
    <a target="_blank" rel="noopener" href="/docs/contribution-guidelines/contribution/first-pr/" aria-label="看这里">
      <i class="fab fa-github"></i>
    </a>
  </li>
  
</ul>

        
        
      </div>
      <div class="td-footer__copyright-etc col-12 col-sm-4 text-center py-2 order-sm-2">
        <span>&copy; 2023 SOFAServerless 开源社区 保留所有权利</span>
        
        
      </div>
    </div>
  </div>
</footer>
    </div>
    
  <script src="/js/main.min.1eb4262674b2d02aa8d18559fef13b166dbdfa627fd0a495c66e11577c026aa3.js" integrity="sha256-HrQmJnSy0Cqo0YVZ/vE7Fm29&#43;mJ/0KSVxm4RV3wCaqM=" crossorigin="anonymous"></script>
<script src='/js/prism.js'></script>
<script src='/js/tabpane-persist.js'></script>

  </body>
</html>